﻿;########################################################;
;#      DEFINITIONS FOR 179X FLOPPY DISK CONTROLLERS    #;
;########################################################;


;       179X floppy disk controller port definitions:


FDCSR   equ     FDBASE          ; command/status port (in/out)
FDTRK   equ     FDCSR+1         ; track register (in/out)
FDSEC   equ     FDTRK+1         ; sector register (in/out)
FDDAT   equ     FDSEC+1         ; data register (in/out)


;       179X floppy disk controller command definitions:


FRCINT  equ     0d0h            ; force interrupt cmd (set type 1 sts)
HOMCMD  equ     00h             ; restore drv to trk 0 cmd
STICMD  equ     50h             ; step in cmd
SEKCMD  equ     10h             ; seek cmd
RDCMD   equ     88h             ; read single IBM record cmd
WRTCMD  equ     0a8h            ; write single IBM record (with data mark) cmd
WTKCMD  equ     0f0h            ; write track cmd


;       179X floppy controller bit and mask definitions:


VERIFY  equ     04h             ; FD179X verify mask for type I cmds
LODHD   equ     08h             ; FD179X head load flag mask for type I cmds
EBIT    equ     2               ; FD179X E flag bit position
FCRCB   equ     3               ; crc error status bit
RNFBIT  equ     4               ; record not found status bit position
HLDBIT  equ     5               ; head load status bit position
SETSF1  equ     1               ; bit to set side flag to 1
WRTBIT  equ     5               ; bit position used to distinguish write cmd
RDMSK   equ     10011100b       ; read status error mask
WRTMSK  equ     11111100b       ; write status error mask